<template>
  <div class="address-box">
    <s-header :name="'地址管理'" :back="from == 'create-order' ? '' : '/user'"></s-header>
    <div class="address-item">
      <van-address-list
        v-if="from != 'mine'"
        v-model="chosenAddressId"
        :list="list"
        default-tag-text="默认"
        @add="onAdd"
        @edit="onEdit"
        @select="select"
      />
      <van-address-list
        v-else
        v-model="chosenAddressId"
        :list="list"
        default-tag-text="默认"
        @add="onAdd"
        @edit="onEdit"
      />
    </div>
  </div>
</template>

<script>
import sHeader from '@/components/SimpleHeader'
import { reactive, toRefs, onMounted } from 'vue'
import { useRouter, useRoute } from 'vue-router'
import { getAddressList } from '@/service/address'
export default {
    components:{
        sHeader
    },
    
    setup(){
        const router = useRouter(); 
        const route = useRoute();
        const state = reactive({
            chosenAddressId:'1',
            list:[],
            from: route.query.from
        })

        onMounted(async () => {
            const { data } = await getAddressList()
            if (!data) {
                state.list = []
                return
            }
            state.list = data.map(item => {
                return {
                id: item.addressId,
                name: item.userName,
                tel: item.userPhone,
                address: `${item.provinceName} ${item.cityName} ${item.regionName} ${item.detailAddress}`,
                isDefault: !!item.defaultFlag
                }
            })
        })
        const onAdd = () =>{
            router.push({ path: 'address-edit', query: { type: 'add', from: state.from }})
        }
        const onEdit = (item) =>{
            router.push({ path: 'address-edit', query: { type: 'edit', addressId: item.id, from: state.from }})
        }
        const select = (item) =>{
            router.push({ path: 'create-order', query: { addressId: item.id, from: state.from }})
        }
        return {
            ...toRefs(state),
            onAdd,
            onEdit,
            select
        }
    }
}
</script>

<style lang="scss" scoped>
@import '@/common/style/mixin';
  .address-box {
    .van-radio__icon {
      display: none;
    }
    .address-item {
      .van-button {
        background: $primary;
        border-color: $primary;
      }
    }
}
</style>